草庐IT

python - 在 Django 模型中制作树结构?

全部标签

ruby - 定义 "method_called".. 如何制作一个钩子(Hook)方法,每次调用类的任何函数时都会调用该方法?

我想制作一个钩子(Hook)方法,每次调用一个类的任何函数时都会调用它。我试过method_added,但是它只在类定义的时候执行一次,classBasedefself.method_added(name)p"#{name.to_s.capitalize}Method'sbeencalled!!"enddefap"acalled."enddefbp"bcalled."endendt1=Base.newt1.at1.bt1.at1.bOutput:"AMethod'sbeencalled!!""BMethod'sbeencalled!!""acalled.""bcalled.""acal

ruby-on-rails - 在 Rails 模型中动态生成范围

我想动态生成作用域。假设我有以下模型:classProduct我们可以用基于POSSIBLE_SIZES常量的东西替换scope调用吗?我认为我违反了DRY以重复它们。 最佳答案 你可以做classProduct但我个人更喜欢:classProduct 关于ruby-on-rails-在Rails模型中动态生成范围,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/14061595/

ruby - 覆盖 Mongoid 模型的 setter 和 getter

有没有办法在Mongoid中覆盖模型的setter或getter?像这样的东西:classProjectincludeMongoid::Documentfield:name,:type=>Stringfield:num_users,type:Integer,default:0key:namehas_and_belongs_to_many:users,class_name:"User",inverse_of::projects#Thiswillnotworkdefname=(projectname)@name=projectname.capitalizeendendname方法可以在不使

ruby-on-rails - 带有字符串输入的引用模型

假设我希望创建一个页面,该页面可以使用type(string)和id(int)查询所需的对象。/query?type=people&id=1会接我Person.find(1)鉴于/query?type=cities&id=123会接我City.find(123)但是,关于如何将字符串转换为所需的模型类,我遇到了问题。我能想到的唯一办法是caseparams[:type]when'people'@object=Person.find(params[:id])when'cities'@object=City.find(params[:id])end但是,如果我有更多类型的模型,这种方法就会

ruby-on-rails - rails 模型的默认值

迁移时设置默认值好还是回调时设置默认值好?很难在迁移中删除(或设置另一个)默认值,但在模型中它多了一段代码 最佳答案 在迁移中定义默认值也有一些缺点。当您只调用Model.new时,这将不起作用。我更喜欢写after_initialize回调,它让我设置默认属性:classModel 关于ruby-on-rails-rails模型的默认值,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questio

ruby-on-rails - 如何从 YAML 文件加载一些 ActiveRecord 模型并将它们保存到数据库?

我正在尝试将一些查找表数据保存到YAML文件中,以便稍后当我需要在另一台机器上设置我的应用程序时,我可以将数据作为种子数据加载。数据是选择选项之类的东西,而且几乎已经设置好,所以不用担心序列化和反序列化之间的实时数据变化。我已经输出了这样的数据......file=File.open("#{RAILS_ROOT}/lib/tasks/questions/questions.yml",'w')questions=Question.find(:all,:order=>'order_position')file我可以像这样加载文件...questions=YAML.load_file('li

ruby-on-rails - 在rails 4中设计用户模型中保存自定义字段

我设计了一个用户模型并向其添加了额外的字段。当我创建和帐户时,一切正常,只有电子邮件、pw和pwconf。然后我想让用户进入编辑页面并填写可选的附加字段。但是,当他们提交时,所有内容都保存为nil。classRegistrationsControllertruerespond_withresource,:location=>after_update_path_for(resource)elseclean_up_passwordsresourcerespond_withresourceendenddefuser_paramsparams.require(:user).permit(:em

ruby-on-rails - ActiveRecord::Base 不属于从 ActiveRecord 降级的层次结构

我正在尝试创建一个Rails插件。在大多数情况下,我写的作品。但是,关联存在问题。当我尝试调用关联时,出现此错误:ActiveRecord::Basedoesn'tbelonginahierarchydescendingfromActiveRecord目前,插件看起来像这样:moduleControlledVersioningmoduleActsAsVersionableextendActiveSupport::Concernincludeddohas_many:versions,as::versionableafter_create:create_initial_versionend

ruby - 组织 Ruby 测试文件夹结构的最佳实践是什么?

在Java中,通常您会创建两个具有相同包层次结构的源文件夹src和test。在Ruby中,您是否只是将所有测试放在与被测类相同的文件夹中?还是在单独的文件夹中创建类似的层次结构?如果是这样,您如何管理单元测试中的require路径? 最佳答案 起初,每个gem都有一个典型的布局。代码几乎完全在lib中。在根目录中,只有README、gemspec文件和一些可选配置数据等元数据。如果您使用Rails或Sinatra之类的工具编写Web应用程序,则会改用它们的布局标准。尽管在所有这些项目类型中,都可以在相似的位置找到测试。根据您使用的测

ruby-on-rails - 将 PG::Result 转换为 Active Record 模型

pg-ruby允许您一次性向数据库发送多个查询,这有助于最大限度地减少访问数据库的次数:results=[]conn.send_query('QUERY1;QUERY2;QUERY3')conn.blockwhileresult=conn.get_resultresults假设对于任何result我已经知道ActiveRecord模型,将结果转换为模型的合适方法是什么?现在我正在做以下事情:fields=result.fieldsmodels=result.values.map{|value_set|Model.new(Hash[fields.zip(value_set)])}该方法的